<template>
<div class="wrapper">
              <v-head></v-head>
              <v-sidebar></v-sidebar>
              <div class="content-box" :class="{'content-collapse':collapse}">
                  <div class="content_wrapper">
                      <v-tags></v-tags>
                      <div class="container messageboard">
                              <!-- 查询区----start -->
                              <el-form :label-position="labelPosition" :label-width="labelWidth" :inline="true" ref="formSearch" :model="formSearch" class="demo-form-inline">
                                  <el-form-item label="昵称" prop="name">
                                      <el-input v-model="formSearch.name" placeholder="模糊匹配"></el-input>
                                  </el-form-item>
                                  <el-form-item label="城市" prop="city">
                                      <el-input v-model="formSearch.city" placeholder="城市"></el-input>
                                  </el-form-item>
                                  <el-form-item label="类别" prop="type">
                                      <el-select v-model="formSearch.type" placeholder="活动区域">
                                          <el-option label="留言" value="1"></el-option>
                                          <el-option label="建议" value="2"></el-option>
                                          <el-option label="BUG" value="3"></el-option>
                                      </el-select>
                                  </el-form-item>

                                  <el-form-item label="年龄" prop="age">
                                      <el-input type="number" v-model="formSearch.age" placeholder="年龄"></el-input>
                                  </el-form-item>
                                  <el-form-item label="性别" prop="gender">
                                      <el-select v-model="formSearch.gender" placeholder="性别">
                                          <el-option label="男" value=1></el-option>
                                          <el-option label="女" value=2></el-option>
                                      </el-select>
                                  </el-form-item>
                                  <el-form-item label="qq号" prop="qq">
                                      <el-input v-model="formSearch.qq" placeholder="qq号"></el-input>
                                  </el-form-item>
                                  <el-form-item label="创建时间" prop="createtime">
                                      <el-date-picker
                                          v-model="formSearch.createtime"
                                          type="daterange"
                                          range-separator="至"
                                          start-placeholder="开始日期"
                                          end-placeholder="结束日期">
                                      </el-date-picker>
                                  </el-form-item>
                                  <el-form-item label=" " style="margin-left:50px;">
                                      <el-button type="primary" @click="onSearch">查询</el-button>
                                      <el-button type="warning" plain @click="onReset">重置</el-button>
                                  </el-form-item>
                              </el-form>
                              <!-- 查询区----end -->
                              <!-- 操作区----start -->
                              <el-row class="mgb15">
                                  <el-button size="small" round type="primary" @click="handleAdd">新增</el-button>
                                  <el-button size="small" round type="danger" @click="deleteMany">批量删除</el-button>
                              </el-row>
                              <!-- 操作区----end -->
                              <!-- 表格---start -->
                              <el-table :data="tableData" v-loading="listLoading"  border stripe style="width: 100%" @selection-change="handleSelectionChange">
                                  <el-table-column type="selection" width="60">
                                  </el-table-column>
                                  <el-table-column prop="name" label="昵称" width="150" align="center" sortable>
                                       <template slot-scope="scope">
                                          <a href="javacript:;" style="color: #00D1B2" @click="openDetail(scope.row)">{{ scope.row.name}}</a>
                                      </template>
                                  </el-table-column>
                                  <el-table-column prop="city" label="城市" align="center" width="150">
                                  </el-table-column>
                                  <el-table-column prop="type" label="类别" align="center" width="150">
                                       <template slot-scope="scope" align="center" width="150">
                                          <span>{{ scope.row.type |convertType}}</span>
                                      </template>
                                  </el-table-column>
                                   <el-table-column prop="age" label="年龄" align="center" width="100">
                                  </el-table-column>
                                  <el-table-column prop="gender" label="性别" align="center" width="100">
                                       <template slot-scope="scope">
                                          <span>{{ scope.row.gender==1?'男':'女' }}</span>
                                      </template>
                                  </el-table-column>
                                  <el-table-column prop="createtime" label="创建日期" :formatter="this.$common.timestampToTime" width="180" sortable>
                                  </el-table-column>
                                   <el-table-column prop="updatetime" label="更新日期" :formatter="this.$common.timestampToTime" width="180" sortable>
                                  </el-table-column>
                                  <el-table-column label="操作" fixed="right" min-width="230">
                                      <template slot-scope="scope">
                                          <el-button size="mini" plain type="primary" @click="handleDetail(scope.$index, scope.row)">详情</el-button>
                                          <el-button size="mini" @click="handleEdit(scope.$index, scope.row)">编辑</el-button>
                                          <el-button size="mini" plain type="danger" @click="handleDelete(scope.$index, scope.row)">删除</el-button>
                                      </template>
                                  </el-table-column>
                              </el-table>
                              <el-pagination background layout="total,sizes,prev, pager, next,jumper" :current-page="pageInfo.currentPage" :page-size="pageInfo.pageSize" :total="pageInfo.pageTotal" :page-sizes="[5, 10, 20, 50]" @size-change="handleSizeChange" @current-change="handleCurrentChange">
                              </el-pagination>
                              <!-- 表格---end -->

                              <!-- 编辑弹框---start -->
                              <el-dialog  :title="formEditTitle" :visible.sync="dialogEdittVisible" width="700px" @close="closeDialog('formEdit')">
                                  <el-form :label-position="labelPosition" :label-width="labelWidth" :rules="rulesEdit" :disabled="formEditDisabled" :inline="true" ref="formEdit" :model="formEdit" class="demo-form-inline">
                                       <el-form-item label="姓名" prop="name">
                                          <el-input v-model="formEdit.name" placeholder="姓名" ></el-input>
                                      </el-form-item>
                                      <el-form-item label="城市" prop="city">
                                          <el-input v-model="formEdit.city" placeholder="地址"></el-input>
                                      </el-form-item>
                                       <el-form-item label="类别" prop="type">
                                          <el-select v-model="formEdit.type" placeholder="类别">
                                              <el-option label="留言" value="1"></el-option>
                                              <el-option label="建议" value="2"></el-option>
                                              <el-option label="BUG" value="3"></el-option>
                                          </el-select>
                                      </el-form-item>
                                       <el-form-item label="年龄" prop="age">
                                          <el-input  v-model="formEdit.age" placeholder="年龄"></el-input>
                                      </el-form-item>
                                       <el-form-item label="性别" prop="gender">
                                          <el-select v-model="formEdit.gender" placeholder="性别">
                                              <el-option label="男" value=1></el-option>
                                              <el-option label="女" value=2></el-option>
                                          </el-select>
                                      </el-form-item>
                                      <el-form-item label="qq" prop="qq">
                                          <el-input v-model="formEdit.qq" placeholder="QQ号"></el-input>
                                      </el-form-item>
                                  </el-form>

                                  <div slot="footer" class="dialog-footer">
                                      <el-button @click="dialogEdittVisible = false">取 消</el-button>
                                      <el-button v-if="!formEditDisabled" type="primary" @click="handleSave">确 定</el-button>
                                  </div>
                              </el-dialog>

                              <!-- 编辑弹框---end -->

                          </div>

                      </div>
                      <v-footer></v-footer>
                  </div>

              </div>
          </div>

</template>

<style lang="scss">
.messageboard{
    // 设置输入框的宽度
    .el-form-item__content {
        width: 220px;
    }
}

</style>

<script>
import apis from '../../apis/apis';
import vHead from '../common/Header.vue';
import vSidebar from '../common/Sidebar.vue';
import vTags from '../common/Tags.vue';
import vFooter from '../common/Footer.vue';
import bus from '../common/bus';
export default {
    name: 'messageboard',
    data() {
        return {
            listLoading : false,//
            pageInfo: { //分页
                currentPage: 1,
                pageSize: 5,
                pageTotal: 80
            },
            formSearch: { //表单查询
                name: '',
                city:'',
                type:null,
                age:'',
                gender:null,
                qq: '',
                startdate:null,
                enddate:null
            },
            formEdit: { //表单编辑
                id:null,
                name: '',
                city:'',
                type:'',
                age:'',
                gender:null,
                qq: ''
            },
             rulesEdit:  {
                name: [
                    { required: true, message: "请输入姓名", trigger: "blur" },
                    { min: 2, max: 4, message: "长度在 2 到 4 个字符", trigger: "blur" }
                ],
                city:[{ required: true, message: "请输入城市", trigger: "blur" }]
                ,
                type: [{ required: true, message: "请选择类别", trigger: "change" }],
                gender: [{ required: true, message: "请选择性别", trigger: "change" }]
            },
            formEditTitle:'编辑',//新增，编辑和查看标题
            formEditDisabled:false,//编辑弹窗是否可编辑
            dialogEdittVisible: false,  //编辑弹框显示
            dialogType:'',//弹框类型：add,edit,show
            tableData: [  //表单列表
                {   id:"1",
                    createtime: "2016-05-02",
                    name: "李紫婷",
                    address: "上海市普陀区金沙江路 1518 弄"
                },
                {
                     id:"2",
                    createtime: "2016-05-04",
                    name: "杨超越",
                    address: "上海市普陀区金沙江路 1517 弄"
                },
                {
                     id:"3",
                    createtime: "2016-05-01",
                    name: "赖小七",
                    address: "上海市普陀区金沙江路 1519 弄"
                },
                {
                    id:"4",
                    createtime: "2016-05-03",
                    name: "张紫宁",
                    address: "上海市普陀区金沙江路 1516 弄"
                }
            ],
            labelPosition: 'right', //lable对齐方式
            labelWidth: '80px', //lable宽度
            formLabelWidth: '120px',
            multipleSelection: []
        };
    },
    components: {
              vHead, vSidebar, vTags, vFooter
          },
    created() {
                  bus.$on('collapse', msg => {
                      this.collapse = msg;
                  })

                  // 只有在标签页列表里的页面才使用keep-alive，即关闭标签之后就不保存到内存中了。
                  bus.$on('tags', msg => {
                      let arr = [];
                      for (let i = 0, len = msg.length; i < len; i++) {
                          msg[i].name && arr.push(msg[i].name);
                      }
                      this.tagsList = arr;
                  })
       },
    computed:{
        
    },
    filters: {
        convertType: function (type) {
            if(type==1){
                return '留言';
            }
            else if(type==2)
            {
                return '建议';
            }
            else if(type==3){
                return 'BUG';
            }
        }
    },
    mounted(){
        this.onSearch();
        var loginLog = {
            ip: returnCitySN["cip"],
            city: returnCitySN["cname"] + "-增删改查页"
        };

        apis.shiroApi.loginLog(loginLog);
    },
    methods: {
        /**
         * 查询列表
         */
        onSearch(){
            this.listLoading=true;
        
            if(this.formSearch.createtime){
                this.formSearch.startdate=this.formSearch.createtime[0];
                this.formSearch.enddate=this.formSearch.createtime[1];
            }
            let param = Object.assign({}, this.formSearch,this.pageInfo);
            apis.msgApi.getList(param)
            .then((data)=>{
                this.listLoading=false;
                if (data && data.data) {
                    
                        var json = data.data;
                        if (json.status == 'SUCCESS') {
                            this.pageInfo.pageTotal=json.count;
                            this.tableData=json.data;
                        }
                        else if (json.message) {
                            this.$message({message: json.message,type: "error"});
                        }
                }
            })
            .catch((err)=>{
                this.listLoading=false;
                this.$message({message: '查询异常，请重试',type: "error"});
            });
        },
        handleSave(){
            if(this.dialogType=='add'){
                this.save();
            }
            else if(this.dialogType=='edit'){
                this.update();
            }
            else{
                this.$message({message: '操作异常',type: "error"});
            }
        },
        /**
         * 保存
         */
        save() {
            this.$refs["formEdit"].validate(valid => {
                if(valid){
                    let param = Object.assign({}, this.formEdit);
                    apis.msgApi.add(param)
                    .then((data)=>{
                        if(data&&data.data){
                            var json=data.data;
                             if(json&&json.status=='SUCCESS'){
                                this.$message({message: '执行成功',type: "success"});
                                this.dialogEdittVisible = false;
                                this.onSearch();
                                return;
                            }
                        }
                       this.$message({message: '执行失败，请重试',type: "error"});
                    })
                    .catch((err)=>{
                        this.$message({message: '执行失败，请重试',type: "error"});
                    });
                }
                
                
            });
        },
         /**
         * 更新
         */
        update() {
            this.$refs["formEdit"].validate(valid => {
                if(valid){
                    let param = Object.assign({}, this.formEdit);
                    apis.msgApi.update(param)
                    .then((data)=>{
                        if(data&&data.data){
                            var json=data.data;
                             if(json&&json.status=='SUCCESS'){
                                this.$message({message: '执行成功',type: "success"});
                                this.dialogEdittVisible = false;
                                this.onSearch();
                                return;
                            }
                        }
                       this.$message({message: '执行失败，请重试',type: "error"});
                    })
                    .catch((err)=>{
                        this.$message({message: '执行失败，请重试',type: "error"});
                    });
                }
                
                
            });
        },
         /**
         * 删除
         */
        handleDelete(index, rowData) {
             if(rowData.name=='使用文档'){
                this.$message('使用文档不可删除');
                return;
            }
            var id=rowData.id;
            this.$confirm('此操作将永久删除该文件, 是否继续?', '提示', {
                confirmButtonText: '确定',
                cancelButtonText: '取消',
                type: 'warning'
            }).then(() => {
                    apis.msgApi.delete({id:id})
                    .then((data)=>{
                        this.$common.isSuccess(data,()=>{
                            debugger;
                            this.onSearch();
                        });
                    })
                    .catch((err)=>{
                        debugger;
                        this.$message({message: '执行失败，请重试',type: "error"});
                    });
                
            }).catch(() => {
                this.$message({type: 'info',message: '已取消删除'});
            });

        },
        /**
         * 批量删除
         */
        deleteMany() {
            var ids= this.multipleSelection.map(item => item.id);
            if(ids.length==0){
                 this.$message({message: '请选择要删除的项',type: "warn"});
                return;
            }
            debugger;
            this.$confirm('此操作将批量永久删除文件, 是否继续?', '提示', {
                    confirmButtonText: '确定',
                    cancelButtonText: '取消',
                    type: 'warning'
                }).then(() => {
                        apis.msgApi.deleteBatch({ids:ids})
                        .then((data)=>{
                            this.$common.isSuccess(data,()=>{
                                debugger;
                                this.onSearch();
                            });
                        })
                        .catch((err)=>{
                            debugger;
                            this.$message({message: '执行失败，请重试',type: "error"});
                        });
                    
                }).catch(() => {
                    this.$message({type: 'info',message: '已取消删除'});
                });

        },
        onReset(){
            this.$refs['formSearch'].resetFields();
        },
        /**
         * 打开编辑弹窗
         */
        handleAdd() {
            this.dialogEdittVisible = true;
            this.$nextTick(()=>{
                this.dialogType='add';
                this.formEditTitle='新增';
                this.formEditDisabled=false;
            });
           
            
        },
        /**
         * 打开编辑弹窗
         */
        handleEdit(index, rowData) {
            //var msg = "索引是:" + index + ",行内容是:" + JSON.stringify(rowData);
            //this.$message({message: msg,type: "success"});
            this.dialogEdittVisible = true;//等dom渲染完，读取data中初始值，然后再复制，这样重置的是data中初始值
            this.$nextTick(()=>{
                this.dialogType='edit';
                this.formEditTitle='编辑';
                this.formEditDisabled=false;
                this.formEdit= Object.assign({}, rowData);
                this.formEdit.gender+='';//必须转换成字符串才能回显
            });  
        },
        /**
         * 打开详情页
         */
        handleDetail(index,rowData){
            this.dialogEdittVisible = true;
            this.$nextTick(()=>{
                 this.dialogType='show';
                this.formEditTitle='详情';
                this.formEditDisabled=true;
                this.formEdit= Object.assign({}, rowData) ;
                this.formEdit.gender+='';
            });
           
        },
        /**
         * 关闭弹框，数据重置
         */
        closeDialog(formName){
            this.$refs[formName].resetFields();
        },
        /**
         * 分页大小切换
         */
        handleSizeChange(val) {
            this.pageInfo.pageSize = val;
            this.onSearch();
        },
        /**
         * 分页切换
         */
        handleCurrentChange(val) {
            this.pageInfo.currentPage = val;
            this.onSearch();
        },
        /**
         * 点击选择
         */
        handleSelectionChange(val) {
            this.multipleSelection = val;
            // this.$message({
            //     message: '选中的项是:' + JSON.stringify(this.multipleSelection),
            //     type: "success"
            // });
        },
        /**
         * 打开详情页
         */
        openDetail(row){
            this.$common.OpenNewPage(this,'detail',row);
        }
        
        
    }
};
</script>
